## 第6章

ソフトウェア無線でディジタル放送やFMラジオ放送を聞く

# 無線受信機の製作

林 輝彦

ここでは通信分野のアプリケーションに適用した例として、ソフトウェア無線 (SDR: software defined radio) の構築を意識したディジタル受信機を設計する. DDC (digital down converter) を用いた DC (direct conversion) 方式の受信機とパソコン上の復調ソフトを組み合わせ、実際に HF 帯の各種放送、通信、VHF 帯の FM 放送を受信できた. (筆者)

ディジタル信号処理技術の進歩によって,アナログ信号処理が中心であった無線システムも大きく様変わりしました.高速 A-D/D-A コンバータと大規模,高性能 FPGA を多数組み合わせた,いわば最先端のソフトウェア無線機が携帯電話の中継,基地局として稼動しています.また,比較的簡単な回路から成るアナログ・フロントエンドをパソコンのサウンド・カードの入力に接続し,パソコン上で受信機を仮想的に構築することもできます(図1).

今回設計したディジタル受信機のブロック図を図2に示します.基本的には、アンテナで捕らえた高周波信号をA-Dコンバータによってディジタル信号にした後、周波数変換を行って、直流(0Hz)付近の周波数を持ったベースバンド信号に変換する、ダイレクト・コンバージョン(DC: direct conversion)受信機の構成をとります.これは、ディジタル処理によって周波数を変換するディジタル・ダウン・コンバータ(DDC: digital down converter)と呼ぶこともあります.位相差90°の直交する局発信号を用いることで、互いに直交するベースバンド(I: in-phase,Q: quadrature)信号を生成し、以降の処理を行います.

信号を直交成分に分けて処理する方法は,アナログの時代から理論的には考案されていました. SSB信号の発生におけるフェーズ・シフト方式や,ウィーバ(Weaver)方式,混信除去のイメージ・リジェクション・ミキサなどです.



(a) ソフトウェア・ラジオ実験基板

(b)復調ソフトウェア

図1 アナログ・フロントエンドと復調ソフトウェアを用いるソフトウェア・ラジオの例 CQ ham radio 2006 年12 月号付録ソフトウェア・ラジオ実験基板と復調ソフトウェア Rocky.

KeyWord

FPGA, ソフトウェア無線, ディジタル・ダウン・コンバータ, ダイレクト・コンバージョン, 数値制御発振器, CIC フィルタ, FIR フィルタ, CORDIC, ハードウェア・アクセラレータ, ディジタル受信機



しかしアナログ方式では,回路を構成する素子の不安定さのため,正確に位相,振幅を管理することが困難だったため,その本格的な実用化はディジタル信号処理の出現を待つことになりました.

DC 方式のディジタル受信機の場合,その中心的な処理内容は,高周波信号を扱うため十分に高く設定したサンプリング周波数(今回は61.44MHz)からベースバンドにおけるフィルタリング,復調などの処理を行うのに適切な,低いサンプリング周波数(今回は48kHzや960kHz,240kHz)までサンプリング周波数を落とす,デシメーション処理を不要なエイリアス信号を混入させることなく行うことです.

### 1. ディジタル受信機の構成要素

ディジタル受信機の構成要素について説明します.

#### ● A-D コンバータ

今回の受信機では,ベースバンドで扱う信号の帯域幅(サンプリング周波数),ダイナミック・レンジとして,それぞれ50kHz,100dB(分解能16ビット程度)を目標に考え



**図3 数値制御発振器(** NCO: numerically controlled oscillator) sin, cos の二つの信号(波形)を同時に出力できる.

ました.

ディジタル受信機の中では,処理が進むに従って,扱う信号の帯域幅を絞ることで目的とする信号を選択し,それに合わせサンプリング周波数も低くしていきます.信号の帯域幅やサンプリング周波数を低くすることにより,振幅方向の分解能は増加するので,アンテナからの高周波信号をディジタル化する A-D コンバータの分解能は,ベースバンドで扱う信号の分解能に比べ小さくても十分です.今回はやサオーバスペックですが,各種の実験ができるよう,分解能14ビット,最高サンプリング周波数65MHzのA-Dコンバータを用いています.

#### ● ミキサ

FPGA に搭載されているハード・マクロの18 ビット×18 ビットの乗算器をミキサとして使用しています.NCO (numerically controlled oscillator)からの直交2相の局発信号をA-D コンバータでディジタル化した高周波信号と掛け合わせ,直流 0Hz 付近の直交2相ベースパンド信号(I信号,Q信号)を生成します.

### NCO (numerically controlled oscillator)

NCOは、周波数データを与えることで、正弦波のディジタル信号出力を得ることのできる発振器です。

図3に示すように,位相アキュムレータによって周波数 データをクロックごとに加算することで位相の瞬時値を計算します.位相をもとにテーブルから正弦波の波形データを得て出力信号とします.

三角関数は,0~2 の変数に対して,振幅+1~-1(変化量:2)の変化をしていて,最大の傾きは1です.波形

## 付属FPGA基板を使った 回路設計チュートリアル Part3



図4 FPGA に実装したNCO のブロック図

ISEの回路図エディタによる設計.三角関数の加法定理を利用してROMテーブルの大きさを大幅に削減する.

データのテーブルとしては、信号の変化率が1程度になるように変数や関数値のスケールを合わせるのがよく、0~2 に対して2、つまり、変数方向のテーブルの細かさを、振幅方向の細かさより 倍大きくとればよいと考えました、具体的には振幅方向の分解能を16ビットとした場合、変数方向の分解能は18ビットに設定するのが合理的であるということになります(今回は、振幅方向の分解能も次段の乗算器の入力ビット幅に合わせ18ビットとしている).

16 ビットのワード幅で18 ビットのワード長のROM は , 512K バイトに達し , 今回使用する FPGA の持つすべての メモリ・プロック( Block RAM )容量である216K ビットを 使っても収まりません . このため今回は , 三角関数の加法 定理を用い , 角度の情報を9 ビット + 9 ビットに分解し , 2 個の512 ワードのROM に波形データを収容しています .

三角関数の加法定理によれば,

$$sin( + ) = sin cos + cos sin$$
  
 $cos( + ) = cos cos - sin sin$ 

です.従って,角度を

$$= + = p + 512 \times q$$
  
(  $= p$ ,  $512 \times q = )$ 

と表すようにすれば , p , q それぞれを 9 ビットの分解能で表現しても としては 18 ビットの分解能を持つことになります .

図4に,加法定理を利用してROMの大きさを削減して 設計したNCOのプロック図を示します.sin\_rom\_mainに は、全周(2 )を512等分したsin,cosのテーブルをそれぞれ18ビット幅(合わせて36ビット幅)で収納し、sin\_rom\_subには、全周の1/512を512等分した角度に対応するsin,cosの値を収納します.二つ目のテーブルは0に近い角度だけを扱うので、sinには0に近い値、cosは1に近い値だけが収納され、MSB側に0や1が集まっています.従って、sin,cosの両方を合わせて36ビットの幅を用意する必要はありませんが、メモリ・ブロック容量を18Kビット以下にしても使用するブロック数は変わらないので、ビット幅を削減することはしていません.同様の理由で、三角関数の対称性を利用して第1象限の波形、テーブルだけで全周に対応する出力を得ることは、動作速度で不利になることも考慮し、今回は採用しませんでした.

#### ● CIC (cascaded integration-comb) フィルタ

CIC フィルタは、25 に示すように,積分器と微分器を組み合わせた SINC フィルタをカスケードに接続しています. SINC フィルタは微分器の遅延段数M に応じ,サンプリング周波数 $f_s$ の 1/M の整数倍の周波数に減衰極,ノッチを生じるフィルタです. 26 に M=4 の例を示します.

1/Mのデシメーションを行う際に問題になるのは,周波数の折り返しによって,目的とする0Hzに近い周波数を持った部分に周波数 $f_s/M$ の整数倍の近傍のエイリアス成分が重なってくることです.デシメーションを行う前に, $f_s/M$ の整数倍の周波数付近の成分を十分に減衰しておく必要があります.206からCICフィルタがこの目的にちょうど良いことが分かります.



図5 CIC(cascaded integration-comb) フィルタの構成

積分器と微分器を組み合わせた SINC フィルタをカスケードに接続する.積分器と微分器をそれぞれまとめ,それらの中間点でデシメーションする方法もある(今回は採用していない).

今回作成した3種類のCICフィルタの仕様を表1にまとめます。基本的にCICフィルタは乗算を含まないので,高速動作をさせやすいフィルタであることもデシメーション用フィルタとして適している理由です。サンプリング周波数61.44MHzで使用するCICフィルタは,メモリ・ブロックは用いずランダム論理として生成しています。そのほかの2種類はメモリ・ブロックを用いたものです。Spartan-3Eのデュアル・ポートRAMでは,同じアドレスに対する読み書きの順序(read after write, read before write など)やパイプラインの段数を設定できるので,こうしたRAMをベースにしたフィルタのアーキテクチャを実装するのに向いています。



図6 CIC フィルタの特性例

cic4\_7\_18a: FM 受信機において  $f_s$  = 3.84MHz から 960kHz への 1/4 デシメーションに使用した.

### ● FIR (finite impulse response) フィルタ

FIR フィルタは図7に示すように,信号を順次遅延させながら,係数を掛け,足し合わせていくことで出力値を求めるフィルタです.

FPGAに実装する場合、デュアル・ポート構成にしたメモリ・ブロックをリング・バッファとして用い、乗算器は各系統で1個ずつ用いる方法で効率良く実装できます(図8).クロック周波数を,サンプリング周波数のタップ数倍以上に設定する必要があるので、RAMをベースにしたアーキテクチャは高速動作には不向きです。しかし今回のディジタル受信機では、CICフィルタでデシメーションの大部分をこなした後、最後の仕上げとして使うので、動作速度はあまり必要とされません、I、Q、2チャネルのフィルタは一つのプロックとして作成するようにしてRAMアドレスの制御回路と係数ROMを共通で使うようにしています。

ヒルベルト変換フィルタも FIR フィルタとして構成されることに変りはありませんが、係数の値が一つ飛びに 0 になり、かつ対称性があるので、係数 ROM の大きさを 1/4 にした上で乗算の回数も 1 サンプリングあたり半分にできます。今回作成した 511 タップのヒルベルト変換フィルタは動作速度的には、256 タップのローパス・フィルタと同様です。

### 表1 実装したCIC フィルタの特 性

最初の減衰極( $f_s/M$ )の減衰特性に注目した.これ以降の減衰極の減衰は最初のそれより大きい.

| フィルタ名       | M          | N         | 入力サンプ       | 通過帯域特性 |        | 減衰極(f <sub>s</sub> /M)付近の特性 |       |  |
|-------------|------------|-----------|-------------|--------|--------|-----------------------------|-------|--|
| 217070      | ( 微分器遅延数 ) | (カスケード段数) | リング周波数      | 周波数    | 減衰量    | 周波数                         | 減衰量   |  |
| aia16 1 10  | 16         | 4         | 61.44MHz    | 200kHz | 0.16dB | 3.84MHz                     | 120dB |  |
| cic16_4_18  | 16         | 4         | 01.44IVITIZ | 200KHZ |        | ± 120kHz                    |       |  |
| cic16 6 22a | 16         | 6         | 3.84MHz     | 24kHz  | 0.6dB  | 240kHz                      | 120dB |  |
| CIC10_0_22a | 16         | O         | 3.04IVITIZ  | Z4KHZ  | 0.0UD  | ± 24kHz                     | 12006 |  |
| cic4_7_18a  | 4          | 7         | 3.84MHz     | 100kHz | 1.1dB  | 960kHz                      | 126dB |  |
|             |            |           |             |        |        | ± 100kHz                    |       |  |

## 付属FPGA基板を使った 回路設計チュートリアル Part3



図7 FIR **フィルタの構成** 

フィルタ係数との乗算結果の総和の計算



図8 リング・バッファを用いたFIR フィルタの 実装

メモリ・ブロックをデュアルポート RAM 構成し、リング・バッファとする、

今回実装した511 タップのヒルベルト変換フィルタの特性を図9に示します.また,今回,各フィルタの係数を求めるために使用した環境と設計仕様を表2にまとめます.

### CORDIC (coordinate rotation digital computer)

CORDIC はベクトルの移動 , 回転を利用してさまざまな関数の計算を行うアルゴリズムで , 三角関数に関する計算によく使われます . 今回はベースバンド信号の位相の情報を求めるために CORDIC を使用した tan -1計算回路を用いています .

アルゴリズムの詳細をここで説明することは避けますが, CORDICのアルゴリズムで,ベクトルを移動させていく際に1回ごとに行う計算は,リスト1のように加減算だけから成ります.ここで,求めようとしている位相角を計算しているのはout p:= in p ± k; の部分で,このkは



図9 511 タップ・ヒルベルト変換フィルタの特性例

 $f_L=0.0032$  ,  $f_H=0.4968$  ,  $R_p=0.017$ dB で設計したもの.正の周波数(0~0.5)を抑圧するよう,Q信号にヒルベルト変換フィルタを通用し,I信号と加算した場合の伝達特性. - 60dB の抑圧比を目標に設計した.

定数やROMの内容としてあらかじめ用意しておきます.

図10は,tan-1関数を計算するx,y(1信号,Q信号の瞬時値)の入力として18ビットの分解能で値を取り込み,位相出力としてやはり18ビットの値を出力するようにして,その精度を確認したものです.内部で位相の値を順次,加減算して蓄積していくアルゴリズムなので,出力の分解能と同様なビット数で処理を行った場合,量子化誤差が蓄積してしまうため,十分な精度が得られません.

図11 は内部の処理を20 ビットまで拡張して18 ビットの精度が得られるようにしたもので,今回のFM 復調に用いています.

#### リスト1 CORDIC の計算

### 2. フィルタの特性を評価する

ディジタル受信機では何種類ものフィルタを使うので、それらの特性が設計した通りに実現できているか、個別に確認しておく必要があります.その理由は、全体を組み上げてから問題が明らかになってもなかなか対処が難しいからです.フィルタの特性評価では、フィルタの応答が安定するまで十分なクロック数、シミュレーションを実行する必要があり、詳細な特性を見るために、周波数をスィープする刻みを小さくしていくと膨大なシミュレーション時間がかかってしまいます.

### ● FPGA 基板をハードウェア・アクセラレータにする

設計の時点ですでに FPGA の載った基板が利用できるのならば,フィルタの制御回路関連の検証をソフトウェアの論理シミュレータ(ISE に標準搭載のシミュレータなど)で確認したら,詳細なフィルタの特性の評価は FPGA 上で実施するのが有効な方法です.

表2 実装したFIR フィルタの特性 と設計環境

|              |                                                      |           | 通過帯域特性                             |           | 阻止域特性    |       |                                 |  |
|--------------|------------------------------------------------------|-----------|------------------------------------|-----------|----------|-------|---------------------------------|--|
| フィルタ名 タップ    |                                                      | サンプリング周波数 | 周波数                                | 減衰量 (リブル) | 周波数      | 減衰量   | 設計環境                            |  |
| dfir256      | 256                                                  | 240kHz    | ~ 22.0kHz                          | 0.25dB    | 26kHz ~  | 122dB | MATLAB/                         |  |
| dfir256a     | fir256の出力ビット幅を18ビット拡張したもの( dfir256 は16 ビット ) . 特性は同じ |           |                                    |           |          |       | Simulink                        |  |
| dfir64       | 64                                                   | 960kHz    | ~ 100kHz                           | 1.0dB     | 140kHz ~ | 83dB  | FDA ツール                         |  |
| hilbert511   | 511                                                  | 48kHz     | $f_L$ =153.6Hz<br>$f_H$ =23846.4Hz | 0.017dB   | -        |       | FIR フィルタ<br>設計ツール <sup>1)</sup> |  |
| hilbert511sr | r 256 段シフト・レジスタ( hilbert511 との遅延調整用.フィルタではない.)       |           |                                    |           |          |       |                                 |  |



図10 CORDIC をtan - 1 計算回路として構成した場合の誤差の例内部の演算精度を,入出力信号のビット数と同じ18 ビットとした例. 最大4LSBほどのエラーが発生している.



**図**11 **内部演算を**20 **ビットとした**18 **ビット**tan <sup>-1</sup>**計算回路の誤差** 量子化誤差と同等のエラー量に収まった.やや+側に変位.

今回筆者が作成した受信機基板には,USB-シリアル変換用ICを搭載しています.フィルタからの出力信号のサンプル値を,このICを通して出力します.パソコン側では一般的な通信ソフト(例えばWindowsに標準のハイパーターミナルなど)でこのデータを取り込むことができるので,ファイルに書き出して表計算ソフトで処理し,フィルタの周波数特性を処理,表示します.

2048点の周波数での応答を1/100sごとに計測してパソコンに送り出す場合,測定時間は約20sとなります.1/100sという時間は,実機においては61.44MHzの主クロックの614,400クロックに相当し,フィルタの応答が整定する時間に比べ十分に長い時間です.シリアル・ポートの速度として115.2kbpsを用いるなら,1/100sに1,152ビットを送出できます.これは100文字近い情報に相当します(I,Q信号それぞれ24ビット幅なら16進表示で12文字必要).

### ● 直交性を利用して1回のサンプリングで測定する

通常,フィルタの周波数特性を測定するためには,フィルタの入力に一定振幅の正弦波を与え,フィルタの出力に現れる出力信号のレベルを測定します.出力信号のレベルを測定するためになんらかの平均をとる必要のある計測方法は,多数の測定値を必要とし,煩雑で時間もかかります.

今回のディジタル受信機の設計では,直交するI,Q信号を扱う関係で,同じ特性を持ったフィルタを2系統実装することになります.一方,局発用の信号源として用意するNCOからは,直交2相の二つの出力が同時に得られます.今回の測定では,この局発用のNCOからの出力を2系統のフィルタに入力し,その二つの出力(これらも当然,直交する)をフィルタの特性測定に用います.

常に互いに90 °の位相差をもっていて,振幅の等しい二つの信号の振幅を測定する場合,三角関数の特性,

$$\sin^2 x + \cos^2 x = 1$$

を利用し,二つの信号の任意の時刻の瞬時値を1回だけ測定することで,複数サンプル点のデータを平均することなく,瞬時に振幅が測定できます.つまり,二つの信号を $A\sin(t)$ と $A\cos(t)$ とすれば,ある時刻における二つの信号の瞬時値,x, yを測定すると,

$$x^2 + y^2 = A \sin^2(t) + A \cos^2(t) = A^2$$

となって振幅Aがただちに求まります.

図 12 に , M = 16 , 4段カスケードの CIC フィルタを評価する場合の ISE 上での回路図を , 図 13 にパソコンで取得した振幅データの例 , 図 14 にグラフ化した周波数特性を示します .



図 12 CIC フィルタの特性をFPGA 上で評価する



図13 CIC フィルタの特性評価のデータ取得のようす Windows 付属のハイパーターミナルによるデータ取得の例.

まったく同じフィルタの特性評価を ISE に付属のシミュレータで実施した場合,一つの周波数のクロック数をフィルタが整定するのに最低限必要な1000クロック程度にまで減らしても,3GHz動作の Pentium 4のパソコンで12分程度かかりました.20s で結果が得られるこの方法は,回路のデバッグ,修正にかかる効率が良いことを実感できます.256 タップの FIR フィルタにいたっては,サンプリング周波数とフィルタのクロック周波数に256 倍の開きがあり,さらに長い時間(5時間程度)を要し,シミュレーションだけの検証はさらに困難になります.以上の方法は FPGA 自体をいわば「ハードウェア・アクセラレータ」として利用していると言えるでしょう.

### 3. ディジタル受信機の製作

これまでに説明してきたNCO, CICフィルタ, FIRフィルタ, CORDICを組み合わせてディジタル受信機を構成し,付属FPGA基板に実装して動作させた例を紹介します.

付属 FPGA 基板を動作させるために用意した基板(以降,受信機基板と呼ぶ)の回路図を図15に,外観を写真1に示します.今回は受信機基板に付属 FPGA 基板を2枚搭載できるようにしています.ディジタル受信機のDDC部だけ



図 14 *M* = 16,4 **段カスケード** CIC **フィルタ** cic16\_4\_18 **の特性** サンプリング周波数 61.44MHz 3.84MHz,1/16 のデシメーションを行う.

でなく、各種、多様な復調アルゴリズムをFPGAに搭載して実験する場合には、今回のFPGA、25万ゲート相当だけでは規模が不足することが出てくると考えたためです。筆者は、本誌2005年1月号の付属FPGA基板(Spartan-3ファミリのXC3S50を搭載)を片側に装着しましたが、本号の付属FPGA基板を2枚使用することもできます。

付属 FPGA 基板にはクロック発振器として 61.44MHz の 水晶発振ユニットを搭載しました . 3.3V のレギュレータは 受信機基板側に搭載したので付属 FPGA 基板には搭載して いません . 受信機基板への供給電圧は 5V としています . (5V の電源は A-D コンバータ , 光送信モジュールに使用 . ノイズやリプルが十分に少ない電源を供給する必要がある ).

アンテナからの高周波信号は,必要に応じてプリアンプ で36dB 程度増幅し,61.44M サンプル/s で A-D 変換を行 い,出力ディジタル・データを付属 FPGA 基板に取り込み ます、付属 FPGA 基板からの出力はディジタル・オーディ オ・インターフェースであるS/PDIFによって出力し,パ ソコンのサウンド・カードに接続してパソコン上で実行す る復調ソフトウェアを利用します. もちろん, FPGA内で 復調まで実施すれば,ディジタル・アンプやオーディオ用 D-A コンバータを接続してスピーカを鳴らすこともできま す.今回は光リンクを利用するため,東芝の光送信モ ジュール「TOTX173」を搭載しています.英国FTDI (Future Technology Devices International)社のUSB-シ リアル変換チップ「FT232R」は,パソコンとの制御系のイ ンターフェースのために用意したものです. 受信周波数や 各種パラメータの設定, 受信信号の情報をパソコンとやり とりするために利用します.16文字×2行のLCDモジュー

## 付属FPGA基板を使った 回路設計チュートリアル Part3



#### 図15 ディジタル受信機基板の回路図

プリアンプ部は別基板に実装し,必要に応じて A-D コンバータの入力に挿入する.定数表記のないコンデンサは  $0.1~\mu$  F チップ・コンデンサ. $10~\mu$  F と  $330~\mu$  F は OS コン .



### 写真1 ディジタル受信機基板

2枚目の FPGA 基板は本誌 2005年1月号の付属 FPGA 基板( XC3S50 搭載 ) . ルは局名, 受信周波数, 設定パラメータの表示などに用います.

この程度の規模の基板であればユニバーサル基板とピッチ変換基板を用いて実装することもできますが、今回は無償で利用できるプリント基板設計ツール「PCBE 注1」でパターンを設計し、感光基板を使って自作してみました。高速な A-D コンバータは、多層のプリント基板を用い、グラウンド・プレーンによって安定な接地電位、シールドを確保しないと、仕様に示された性能を得ることは困難です。今回のような片面だけのパターン、あるいはピッチ変換基板の使用は無謀ですが、無信号時の A-D 変換出力の FFT 結果を見る限り、問題はないと判断しました。

付属 DVD-ROM に収録した設計データには, PCBE による基板パターン・データも収録しましたのでファイトのある方は挑戦してみてください.

注1:http://www.vector.co.jp/soft/win95/business/se056371.htmlからダウンロードできる

#### ● DDC と復調ソフトによる受信機

最初の例は,受信信号をDDCによってベースバンドのI,Q直交信号に変換し,S/PDIFディジタル・オーディオ・インターフェースによってパソコンのサウンド・カードに入力,パソコン上の復調ソフトウェアを使って復調するものです.アナログ方式のフロントエンドを用いるソフトウェア・ラジオを完全にディジタル化したものと考えればよいでしょう.

図16にISEで記述したトップレベルの回路図を示します.A-D コンバータからの出力(61.44M サンプル/s)は,二つの乗算器によって直交する局発信号を掛け合わせ,ベースバンド信号に変換します.NCO のクロック周波数は61.44MHz なので,基本的には受信周波数はその1/2,DCから30.72MHz ということになります.今回使用した A-Dコンバータは入力周波数240MHz 程度までのアンダサンプリングに対応できるので,適切な帯域フィルタを A-D コンバータの前に挿入すれば第7~第8ナイキスト・バンド



パソコン上で実行する復調ソフトウェアを組み合わせて受信機として動作する. 受信周波数はconst\_gen28a内の定数で設定.

## 付属FPGA基板を使った 回路設計チュートリアル Part3

(ゾーン)である240MHz 程度まで受信可能です(次に示す FM 放送受信ではこの方法を用いる).

NCOの周波数の設定,すなわち受信周波数の設定はパソコンとのUSB接続によって行うことができます(本稿執筆段階ではこの機能は未実装.NCOの周波数は28ビットの定数で設定しているので,受信周波数を変更するためには,FPGAの書き換えが必要).周波数 $f_R$ を受信する際にNCOに与える周波数データ $f_{DATA}$ は,NCOの与えるクロック周波数を $f_{CLK}$ とすれば以下のように計算できます.

$$f_{DATA} = 2^{28} \times f_R / f_{CLK}$$
  
= 268,435,456 ×  $f_R$ ( Hz )/ 61,440,000

DDCの設計の中心的な作業は、適切なフィルタリングによってサンプリング周波数を落とすデシメーション用低域フィルタの設計を行うことにあります。この例ではパソコン上で実行する復調ソフトウェアのための入力信号を生成する必要があるので、サンプリング周波数を A-D コンバータの 61.44MHz から 48kHz に落とすようにしています。

最初のCIC フィルタ(cic16\_4\_18)では,M=16 のSINC フィルタを4段カスケードに接続し,サンプリング周波数を1/16の3.84MHz に落とします.次の段のCIC フィルタ (cic6\_22\_18a)ではやはりM=16 としていますが,24kHz離れた周波数でのエイリアス信号を120dB 程度,減衰できるよう,カスケードの段数を6段としています.この2段目のCIC フィルタは動作周波数が低い(3.84MHz)ので,メモリ・ブロックをデュアルポート構成にして用い,必要な

信号の遅延をメモリ上で実現し,コンパクトにまとめています.

クロック周波数としてはサンプリング周波数の16倍である61.44MHzを用い,構成を変更することなく信号を取り出す位置を変えることで,I,Q,2チャネル分のCICフィルタを,カスケード段数,最大8段まで自由に設定し実装できます.CICフィルタを2段,通った段階でサンプリング周波数は240kHzにまで落とされていて,2段のCICフィルタによる総合的な周波数特性は**図**17に示すようになります(入力のサンプリング周波数 $f_s$  = 61.44MHzの全域での応答を確認し,480kHz以上の周波数で - 100dBを超える応答はない).最終段においては通過帯域と阻止帯域を明確に区別する特性を実現できるFIR型のローパス・フィルタ(dfir256)を通すことで,目的とする周波数帯域だけを残すようにします(**図**18).

#### ● 復調ソフトウェア

アナログ方式のフロントエンドを用いる場合に使ったソフトウェア・ラジオ用の復調ソフトウェアが利用できます. 図19はPowerSDRという復調ソフトウェア(http://flex-radio.com/)を使って航空無線,11330kHzを受信しているようすです.このソフトウェアは,受信機として非常に豊富な機能を備えており,送信用ベースバンド信号を発生することも可能です.PowerSDRの場合,I,Q信号の極性の関係から,周波数を正しく認識させるためS/PDIFの入力の接続を左右,逆にする必要があります.



**図**17 **二つの**CIC **フィルタの総合特性** 

480kHz 以上の周波数で - 100dB を超える応答がないことを確認 . エイリアスの混入してくる可能性のある周波数帯が十分に除去されている .



図 18 CIC フィルタとFIR フィルタの総合特性

22kHzまでの通過帯域内に見られるリプルはFIR フィルタによるもの. 緩やかに通過帯域高端で減衰が見られるのはCIC フィルタの特性による.



図19 PowerSDR を用いてSSB 信号を復調した例

11.330MHz は航空機の洋上管制,東京コントロール(NP: North Pacific エリア)の周波数のつっ. PowerSDR を使用する時はS/PDIF 入力の左右を入れ替えてコンフィグレーションする.

PowerSDR以外ではSDRadio(http://digilander.libero.it/i2phd/sdradio/), Rocky(http://www.dxatlas.com/Rocky/)といったソフトウェアがよく使用されています.

図20はDream(http://drm.sourceforge.net/)というソフトウェアによって,OFDM変調によって短波帯で実施されているDRM(Digital Radio Mondiale)放送を受信している様子です.Dreamでは直交2相の1信号,Q信号を入力とするモード(-c の引き数として3~6の値を用いる)が利用できるので,このDDCからの出力を,I信号を左チャネル,Q信号を右チャネルに入力することでDRM放送を受信することができます.

現在,感度やダイナミック・レンジなど,受信機としての性能評価を始めていますが,36dBのプリアンプを挿入した状態で,PowerSDR,Dreamといった復調ソフトウェアと組み合わせた場合,アナログ方式の通信型受信機と十分互角の性能があります.

### ● CORDIC を搭載して FM 放送を受信してみる

信号の復調をパソコン上で実行するソフトウェアで行えば、各種の変調方式に柔軟に対応できますが、サウンド・カードをデータのインターフェースとするため、扱うことのできる周波数帯域、変調方式は限られます、今度はFPGA上に復調部を搭載することで、さらに、多様な変復調方式に対応することを試みることにします。

図21はCORDICをFM復調のための位相検出器として 用いた受信機で,FM放送(最大周波数偏移75kHz)を受信



図20 Dream **によって** DRM **放送を復調した例** ドイチェ・ベレ( Deutsche Welle )の DRM 放送( 13790kHz , 5 月13日, 0157JST )を受信,復調した例.

するように構成したものです.

日本国内のFM放送は,最大周波数偏移75kHzのFM変調が行われていて,通常のステレオ放送の場合,受信帯域幅として最低,200kHz程度必要になります.先のDDCでは最終的にサンプリング周波数を48kHzまで落としているので,帯域幅200kHzを必要とするFM放送の復調は不可能です.ここでは,61.44MHzのサンプリング周波数を3.84MHzに落とした後,M=4,7段カスケードのCICフィルタ(cic\_4\_7\_18a)によってサンプリング周波数を960kHzへ落とし,カットオフ周波数100kHzの64タップのFIRローパス・フィルタ(dfir64)によって必要な帯域を取り出した後,CORDIC(cordic18x)による位相検波を行います.

図22は二つのCICフィルタ,FIRフィルタを合わせたCORDIC直前までの総合的な周波数特性です.CORDICからの位相出力は隣接するサンプリング値の差をとって(微分)周波数情報に変換します(pmfm).S/PDIFへ出力する音声信号はdfir256によって22kHz以上の,耳で聴くには不要な成分をカットします.

FM放送においては,送信側で高い周波数を強調するエンファシス(emphasis)を行い,受信機側では,送信側のエンファシスとはちょうど反対の周波数特性を持った回路を通すデエンファシス(de-emphasis)を行って,総合的に



フラットな周波数特性を得るようにしています.今回,実 装した回路では,デエンファシス回路は省略しているので, 受信音はやや高音域が強調された音になっています<sup>注2</sup>.

FMステレオ放送の左右の信号を分離する回路はFMマルチプレクス回路と言います.アナログ回路では,PLLやサンプリング回路,各種のフィルタで実現されてきました.先のデエンファシス回路の追加にとどまらず,FPGA上にディジタル信号処理によってこのFMマルチプレックス回路を実現して良好な音質でFMステレオ放送を楽しむのも,おもしろいと思います.

FM 放送の周波数帯( 76MHz  $\sim 90$ MHz )を通常のナイキスト周波数( $f_s$ /2 )の範囲で扱うためには,A-D コンバータのサンプリング周波数は 180MHz 以上にする必要があります.したがって,利用できる A-D コンバータが限られてしまいます.今回使用した A-D コンバータは,最大サンプリング周波数は 65MHz となっていますが,A-D コンバータへの入力周波数としては 240MHz 程度まで扱うことのでき



**図**22 CIC **フィルタと**FIR **フィルタの総合特性(FM 受信機の例)** 400kHz 以上の周波数においては減衰量は100dB 以上となっている.

るアンダサンプリングに対応した A-D コンバータです.このため, A-D コンバータのサンプリング周波数として61.44MHzを使用していても, 例えば, 東京地方の FM 東京の 80.0MHz を受信する時は, **図**23 に示すように第3ナ

注2:付属DVD-ROM に収録したddc\_fmではローパス・フィルタdfir256のクロック周波数を落としfc=4.4kHzとしてあるので,高音域の強調は目立たない.



図23 アンダサンプリングでFM 放送を受信する

イキスト・バンド(ゾーン)に80.0MHzが含まれるので. NCO からは 18.56MHz の局発出力を出力して 80.0MHz を 受信することができます.

図24は A-D コンバータの入力とプリアンプの間に挿入 するバンドパス・フィルタです.この例のように,アンダ サンプリングを用いる場合には必須です、このフィルタに よってアンテナからの高周波信号のうち,80.0MHz付近の

otr\_det

OTR LED

TR\_IN

OTR IN





(b) 外観

図24 FM 放送をアンダサンプリングで受信するための バンドパス・フィルタ

バンドパス・フィルタを用いないと混信やノイズ増加の可能性 がある.

周波数のものだけを A-D コンバータの入力に与えるように します.このフィルタを使用しないとFM用のアンテナを 接続していても、フィルタを使用した場合に比べ、明らか にノイズが増加することが聴くだけでも分かります.

### ■ SSBモードの通信を受信する

ベースバンドに変換されたI信号,Q信号の片方だけに



Q信号側にヒルベルト変換フィルタを挿入する.!信号側は遅延時間を補償するための遅延回路を挿入する.

## 付属FPGA基板を使った 回路設計チュートリアル Part3



図26 受信周波数と受信機出力の関係

いのか,低いのかを区別することはできません.

ヒルベルト変換フィルタは,対象とする周波数帯域において入出力間に90°の位相差を与えるフィルタです.このヒルベルト変換フィルタをI,Q信号の片方に用いて加算,あるいは減算することで,局発信号よりも高い周波数成分,低い周波数成分を区別できるようになります.

図25はQ信号にヒルベルト変換フィルタ(hilbert511)を通し、I信号(遅延時間を合わせるために、256段の遅延回路,hilbert511\_srが挿入されている)と加算,減算することで、左チャネルには局発信号よりも低い周波数に位置する受信信号(LSBモードのSSB信号を受信する場合に用いる)、右チャネルには局発信号よりも高い周波数に位置する受信信号(USBモードのSSB信号を受信する場合に用いる)を振り分けて出力するように構成したものです(図26).

SSBモードは音声帯域をそのまま,高周波の信号に周波数変換する変調方式であって,占有スペクトルも少なく,HF帯においてはアマチュア無線や航空機の洋上管制,船舶無線など,現在でも音声の通信では広く使われています.通常のSSB通信はUSBモードを使って行われるので,この受信機の場合,右チャネルの出力を聴くことになります(アマチュア無線では10MHz未満の周波数ではLSBモードを用いる).

SSB モードは振幅変調の一種なので,入感する受信信号の強度によって復調される音声の大きさは大きく変化します.そのため,AGC(automatic gain control)の機能を実現して受信信号の強度が変化しても復調出力が変動しないよう,ゲインを自動制御しないと実用的な受信機にはなりません.その点でこの受信機の例は直交I,Q信号とヒルベルト変換フィルタの動作を体感するには良い題材ですが,実用的なSSBの受信には先に紹介したPowerSDRのようなソフトウェアが有効です.

#### 表3 設計した回路の合成結果

主クロックのタイミング制約を 16.3ns( 61.44MHz )として,回路の合成,配置配線を行った結果.

| 受信機                  | 4入力<br>LUT | 使用率 | メモリ・<br>ブロック | 乗算器<br>18 × 18 | 最大動作<br>周波数 MHz) |
|----------------------|------------|-----|--------------|----------------|------------------|
| ddc<br>(DDC単体)       | 1336       | 27% | 6            | 8              | 64.3             |
| ddc_fm<br>(FM 受信機)   | 2614       | 53% | 9            | 10             | 61.9             |
| ddc_ssb<br>(SSB 受信機) | 1655       | 33% | 9            | 9              | 62.2             |

#### ● まとめ

表3は今回実装した3種類の受信機のリソースの使用状態,動作速度をまとめたものです。LUTの使用率に比べ,乗算器やメモリ・ブロックの使用率が高く,復調アルゴリズムとして今後,OFDMなどのディジタル変調の方式を試していくにも,DDCを実装したところで,乗算器をほぼ使い切った状況にあります。付属FPGA基板に搭載されたXC3S250Eは,LUTを少し減らしてもよいので乗算器やメモリ・ブロックをもう少し増やしてほしいと感じた面はありますが,今回のような通信系のアプリケーションで実用的な規模の回路を効率良く実装でき,極めて使いやすいFPGAだと思います。

#### 参考・引用\*文献

(1) 西村芳一; ディジタル信号処理による通信システム設計, 2006 年, CQ 出版社.

はやし・てるひこ (株)ソリトン・システムズ

#### <筆者プロフィール> -

林輝彦・根っからの「ラジオ少年」は学校卒業後,何を血迷ったか,米国系のマイクロプロセッサ会社に就職してしまう・いくつかのCPUの開発に関わった後,今の会社に移り,シリコン・コンパイラ,HDLシミュレータ,アナログ合成などのEDAツールの普及に関わる・最近はアナログ設計に回帰しつつあり,ますます元気・